package org.dromara.bzIns.domain.vo;

import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
import org.apache.poi.hpsf.Blob;
import org.dromara.bzIns.domain.InsInsure;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import org.dromara.common.excel.annotation.ExcelDictFormat;
import org.dromara.common.excel.convert.ExcelDictConvert;
import io.github.linpeilie.annotations.AutoMapper;
import lombok.Data;

import java.io.Serial;
import java.io.Serializable;
import java.util.Date;



/**
 * 保单记录视图对象 bz_ins_insure
 *
 * @author bz_huaYal9146
 * @date 2025-03-28
 */
@Data
@ExcelIgnoreUnannotated
@AutoMapper(target = InsInsure.class)
public class InsInsureVo implements Serializable {

    @Serial
    private static final long serialVersionUID = 1L;

    //保险公司图标
    private Blob insCompanyImg;

    //理赔电话
    private String insClaimPhone;

    /**
     * 保单id
     */
    @ExcelProperty(value = "保单id")
    private Long insureId;

    /**
     * 用户id
     */
    @ExcelProperty(value = "用户id")
    private Long userId;

    /**
     * 用户汽车id
     */
    @ExcelProperty(value = "用户汽车id")
    private Long carId;

    /**
     * 车牌号
     */
    @ExcelProperty(value = "车牌号")
    private String carPlate;

    private Long insCompanyId;

    /**
     * 保险公司名称
     */
    @ExcelProperty(value = "保险公司名称")
    private String insCompanyName;

    /**
     * 投保时间
     */
    @ExcelProperty(value = "投保时间")
    private Date insuredTime;

    /**
     * 保障开始时间
     */
    @ExcelProperty(value = "保障开始时间")
    private Date guaranteeStartTime;

    /**
     * 保险金额
     */
    @ExcelProperty(value = "保险金额")
    private BigDecimal insuredAmount;

    /**
     * 实付款
     */
    @ExcelProperty(value = "实付款")
    private BigDecimal actualPay;

    /**
     * 有效期
     */
    @ExcelProperty(value = "有效期")
    private Date expirationDate;

    /**
     * 到期时间(由用户填入有效期和保单生效时间计算）
     */
    @ExcelProperty(value = "到期时间(由用户填入有效期和保单生效时间计算）")
    private Date expirationTime;

    /**
     * 总保额
     */
    @ExcelProperty(value = "总保额")
    private BigDecimal totalInsAmount;

    /**
     * 保单状态：0-未生效，1-生效，2-已过期
     */
    private int checkStatus;

    /**
     * 是否显示  0-显示，1-不显示
     */
    @ExcelProperty(value = "是否显示  0-显示，1-不显示")
    private Long isDisplay;


}
